문제

정수 n과 문자열 control이 주어집니다. control은 “w”, “a”, “s”, “d”의 4개의 문자로 이루어져 있으며, control의 앞에서부터 순서대로 문자에 따라 n의 값을 바꿉니다.

  • “w” : n이 1 커집니다.
  • “s” : n이 1 작아집니다.
  • “d” : n이 10 커집니다.
  • “a” : n이 10 작아집니다.

위 규칙에 따라 n을 바꿨을 때 가장 마지막에 나오는 n의 값을 return 하는 solution 함수를 완성해 주세요.

제한사항

  • -100,000 ≤ n ≤ 100,000
  • 1 ≤ control의 길이 ≤ 100,000
    • control은 알파벳 소문자 “w”, “a”, “s”, “d”로 이루어진 문자열입니다.

입출력 예

n control result
0 “wsdawsdassw” -1

입출력 예 설명

입출력 예 #1

  • 수 n은 control에 따라 다음과 같은 순서로 변하게 됩니다.
  • 0 → 1 → 0 → 10 → 0 → 1 → 0 → 10 → 0 → -1 → -2 → -1
  • 따라서 -1을 return 합니다.

코드

function solution(n, control) {
  const newData = control.split('');
  for (let i = 0; i < newData.length; i++) {
    if (newData[i] === 'w') {
      n += 1;
    } else if (newData[i] === 's') {
      n -= 1;
    } else if (newData[i] === 'd') {
      n += 10;
    } else if (newData[i] === 'a') {
      n -= 10;
    }
  }
  return n;
}

코드 해설

  • 입력된 control 문자열을 배열로 변환하여 newData 변수에 할당한다.
  • 각 문자는 배열의 원소로 들어가고, 배열의 각 원소에 대해 반복문을 사용한다.
  • 현재 원소가 “w”이면, n 값을 1 증가 시킨다.
  • 현재 원소가 “s”이면, n 값을 1 감소 시킨다.
  • 현재 원소가 “d”이면, n 값을 10 증가 시킨다.
  • 현재 원소가 “a”이면, n 값을 10 감소 시킨다.
  • 반복문이 끝나면 n의 최종 값을 반환한다.
  • 이 함수는 control 문자열을 통해 주어진 규칙에 따라 n 값을 조작하고 최종적으로 반환합니다.